草庐IT

Java Swingworker 和多线程

全部标签

java - 什么是java信号调度线程?

我正在查看java进程的线程转储,并注意到一些线程被信号调度程序阻塞。什么是信号调度器?它有什么作用? 最佳答案 我在IBMdeveloperWorks上找到了一篇关于此的文章。当操作系统向JVM发出信号时,信号调度线程会将信号传递给适当的处理程序RevelationsonJavasignalhandlingandtermination作者:ChrisWhite,IBM软件工程师 关于java-什么是java信号调度线程?,我们在StackOverflow上找到一个类似的问题:

java - 如何在一个类中处理多个线程?

线程通常以两种方式设计(seejavatutorials):通过扩展Thread类或通过实现Runnable类。无论哪种方式,您都需要指定将在线程内运行的内容。我设计了一个类,一个针对在线资源的适配器,用于检索不同类型的信息。此类由getInformationOfTypeA()和getInformationOfTypeB()等方法组成。两者都包含连接到在线资源的代码,因此都需要线程化以避免死锁。问题是:我应该如何设计这个?我可以像下面那样做,但是我只能实现一种方法:publicclassOnlineResourceAdapterimplementsRunnable{publicvoid

java - 什么是 Java2D 处理器线程?

我创建了一个使用Hibernate的示例Java应用程序,当我执行线程转储时,我观察到名为Java2DDisposer的奇怪线程。有人能告诉我那个线程的功能吗? 最佳答案 AWT系统中的某些实体需要完成才能释放资源。最突出的示例是java.awt.Windows,它需要在窗口被垃圾回收后释放其native资源。可以使用终结器来做到这一点,但可以为您提供更详细控制的解决方案是将幻像引用与引用队列一起使用。该解决方案需要一个在引用队列上等待的专用线程。该线程是“Java2D处理器”线程,它是在您初始化AWT系统时创建的。

java - 从 Java 中的多个线程写入 FileOutputStream

从多个线程调用JavaFileOutputStream对象上的write是否安全?输出会被正确序列化吗?澄清:在我的例子中,类记录器持有一个FileOutputStream引用,多个线程可以调用记录器写入,格式化输出并调用FileOutputStream写入。我是否应该同步我的记录器写入方法以保证来自多个线程的消息不会混合? 最佳答案 一个文件在write-mode下不能被多次打开,所以答案是否定的。看到您的编辑后,是的,您应该在记录器中引入同步,以确保一次只能由一个线程访问流。只是一个建议,你为什么不去Log4J?它已经处理了您的

java - Akka 中的轻量级线程

我最近读到Quasar它为JVM提供“轻量级”/类似Go的“用户模式”线程(它也有一个Erlang启发的Actor系统,比如Akka但这不是主要问题)例如:packagejmodern;importco.paralleluniverse.fibers.Fiber;importco.paralleluniverse.strands.Strand;importco.paralleluniverse.strands.channels.Channel;importco.paralleluniverse.strands.channels.Channels;publicclassMain{publ

不写脚本,三步实现Jmeter跨线程传参

前言    其实本来是要继续复习python面向对象部分的,但是今天工作闲暇刚好在挂接口测试的东西,闲着没事复习了一下postman的参数化然后觉得有点无聊就想起来jmeter里跨线程组好像也可以传参的,结果有点忘记了最便捷的跨线程传参方法,就记得一个BeanShell取样器提取全局变量,用另外一个前置处理器中的Beanshell调试了半天,感觉真是瞎折腾,这篇文章是翻阅了之前的demo然后顺便复习了jmeter的传参方法顺不下折腾快两小时没搞出来的气来更新的。1.Jmeter关联    关联在这里可能对学过接口测试的人都比较熟悉,其实在之前基础接口测试里面的postman的学习里我也是用的关

java - 在单个后台线程定期修改 map 的同时读取 map

我有一个类,我在updateLiveSockets()方法中每30秒从一个后台线程填充一个映射liveSocketsByDatacenter然后我有一个方法getNextSocket()将由多个读取器线程调用以获取可用的实时套接字,该套接字使用相同的映射来获取此信息。publicclassSocketManager{privatestaticfinalRandomrandom=newRandom();privatefinalScheduledExecutorServicescheduler=Executors.newSingleThreadScheduledExecutor();pri

java - Spring 集成测试消耗大量内存,在 GradleWorkerMain 中使用大量重复线程

我有一个有点复杂的SpringBoot应用程序,包含大量测试。在运行测试时,它似乎积累了很多线程,其中一个线程有多个实例并且被称为SimplePauseDetectorThread_0,我追溯到这个依赖|||\---io.micrometer:micrometer-core:1.1.1|||+---org.latencyutils:LatencyUtils:2.0.3这似乎发生在SpringBoot2.0.6和2.1.1上。一个典型的测试可能是这样的:@RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest(webEnvironmen

java - Java 线程优先级如何转换为操作系统线程优先级?

JavaAPI线程优先级(1-10)如何转换为操作系统级优先级,因为大多数操作系统没有与之匹配的线程优先级(以数字表示)。因此请记住,是否存在两个或多个具有不同优先级的线程最终在操作系统级别获得相同优先级的情况。请澄清,如果我的理解有一些更正。 最佳答案 确实,某些优先级可以映射到相同的“native”优先级。这是列表(基于OpenJDK6中的Hotspot代码):太阳系1⇒02⇒323⇒644⇒965–10⇒127值得注意的是,在Solaris上,您不能将线程优先级提高到正常以上,只能降低它:5的优先级值与任何更高的值相同。Lin

java - java.net.Socket 线程安全的方式是什么?

我有一个Socket,我正在通过BufferedReaders和BufferedWriters读取和写入。我不确定可以从单独的线程执行哪些操作。我猜想同时从两个不同的线程写入套接字是个坏主意。与同时从两个不同线程读取套接字相同。在一个线程上阅读而在另一个线程上写入怎么样?我问是因为我想让一个线程在等待更多数据时长时间阻塞读取,但在等待期间我也偶尔有数据要在套接字上发送。我不清楚这是否是线程安全的,或者我是否应该在写入之前取消读取(这会很烦人)。 最佳答案 套接字在流级别是线程不安全的。您必须提供同步。唯一的保证是无论并发性如何,您都